草庐IT

Java String.split 内存泄漏?

全部标签

.net - XmlDocument缓存内存使用

我们发现在使用XmlDocument的.NETWeb应用程序中内存使用率非常高。一个小的(~5MB)XML文档被加载到XmlDocument对象中并存储在HttpContext.Cache中,以便在每次加载页面时轻松查询和XSLT转换。XML在磁盘上定期修改,因此缓存依赖于文件。这样的应用程序似乎使用了数百兆字节的RAM。我已经尝试在每次请求开始时请求垃圾收集,这使RAM使用率大大降低,但我无法想象这是一个好习惯。对于我们如何以更低的RAM使用量实现相同的目标,有没有人有任何建议? 最佳答案 我的两分钱。..如果内存使用量根据XML

xml - xsl : split and get the X position of param

xsl:我需要拆分并获取X位置参数,@class属性第二个参数:输入XML:567662destacadodestacado:HomeActualidadES我需要的输出XML:567662destacadodestacado:HomeActualidadES我有这个xsl:我用以前的XSL输出XML,我不知道如何获得CLASSATTRIBUTE的第二个参数:(567662destacadodestacado:HomeActualidadES解决方法: 最佳答案 带有模板的更通用的XSLT1.0解决方案。如果您有除root之外没有c

sql-server - SSIS XML XSLT 任务内存不足

我正在BIDS2005中开发一个包,该包以针对非常大的输入文件的XML(XSLT)任务开始,并不断收到以下错误[XMLTask]Error:Anerroroccurredwiththefollowingerrormessage:"Exceptionoftype'System.OutOfMemoryException'wasthrown.我的工作站是Win764位-16GIGRam-i78核处理器3.5gHZ。我在此过程中运行任务管理器,它在运行期间最多只能使用大约7.5gigs的ram,直到它因错误而崩溃。我正在针对我的本地SQL2008R264位实例运行。该包在BIDS中配置为以64

c# - 加载xml文件到内存

我需要在内存中加载一个xml文件,以便我可以从不同的表单多次访问它。xml格式如下:Name1Value1Type1Name2Value2Type2我不想使用数据库来存储变量。还有其他方法可以将数据存储在内存中吗?现在我正在为每张幻灯片和流阅读器使用一个txt文件,我确信这不是最佳选择。编辑:我添加了这段代码,但我是否能够在不再次读取xml文件的情况下每次都获取幻灯片?varslides=fromsinXElement.Load("slides.xml").Elements("Slide")selects;foreach(varslideinslides){//code}

c# - 如何在不将整个文件加载到内存的情况下更新 xml 文件

我们如何在不将xml文件完全加载到内存的情况下更新它。在下面的代码中,我想浏览每个父节点注释并更新to节点的值。我们如何使用C#实现此目的。我必须根据代码中的一些其他计算更新to字段。JaniToveJohnDoe 最佳答案 您可以使用XmlReader和XmlWriter的流式处理方法,您只需从阅读器中写出除您需要更改的部分之外的所有内容。ScottHanselman有一个blog使用此技术发布。 关于c#-如何在不将整个文件加载到内存的情况下更新xml文件,我们在StackOverf

C# XSLT 转换内存不足

全部,我有以下使用XSLT转换XML文档的代码。问题是当XML文档大约为12MB时,C#内存不足。有没有一种不同的方法可以在不消耗那么多内存的情况下进行转换?publicstringTransform(XPathDocumentmyXPathDoc,XslCompiledTransformmyXslTrans){try{varstm=newMemoryStream();myXslTrans.Transform(myXPathDoc,null,stm);varsr=newStreamReader(stm);returnsr.ReadToEnd();}catch(Exceptione){/

java - 从内存而不是磁盘读取文件

我有一个包含大量XML文件(>500)的Java项目。在运行时读取此文件会导致性能问题。是否可以选择将所有XML文件加载到RAM并从那里读取而不是从磁盘读取?我知道有类似RamDisk的产品但这是一种商业工具。我可以将XML文件复制到主内存并使用任何现有的JavaAPI/库从主内存读取吗? 最佳答案 我会首先尝试内存映射文件,由RandomAccessFile提供和FileChannel在标准java库中。这样操作系统就可以将经常使用的文件内容保留在内存中,有效地实现你想要的。 关于ja

java - 使用 scala 处理某些 xml 时出现内存不足错误

我已经将wikixml转储分成许多1M的小部分并尝试清理它(在其他人用另一个程序清理它之后)我遇到了一个内存不足的错误,我不知道如何解决。谁能赐教一下?我收到以下错误消息:Exceptioninthread"main"java.lang.OutOfMemoryError:Javaheapspaceatorg.apache.lucene.index.FreqProxTermsWriterPerField$FreqProxPostingsArray.(FreqProxTermsWriterPerField.java:212)atorg.apache.lucene.index.FreqPro

c# - 使用 dataSet.GetXml() 获取内存

如果数据集太大并且内存足够,我会得到错误“System.OutOfMemoryException”。文件“file1.xml”的大小约为36MB。解决这个问题的方法是什么?提前致谢。privateXPathDocumentGetXML(DataSetds){ds.WriteXml("file1.xml");ds.WriteXmlSchema("file1.xsd");XPathDocumentdoc=newXPathDocument(newStringReader(ds.GetXml()));returndoc;} 最佳答案 您可以

Python解析XML后不释放内存

我正在使用lxml来解析一些相当大的xml文件(每个大约15MB)。而我在概念上做的是以下内容:importlxml.etreeasETdefprocess_xmls():forxml_fileinxml_files:tree=ET.parse(xml_file)etc.etc.现在,我正在调用该函数,我看到内存在增加和增加,这是合理的。问题是,函数结束后,内存仍然很高,而Python不会释放它!为什么会这样,有什么解决方法吗? 最佳答案 可能是lxml调用了malloc(),调用了sbrk()。然后虚拟内存永远不会变小。但这不是世